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CLAIMS 

What is claimed is: 

1. A method for interleaving data elements comprising the steps of: 
writing address locations of the data eleralents sequentially by rows into a 

5 matrix having a predetermined number of bit storage locations arranged in a first 
predetermined number of rows having corresponding row indexes and a second 
predetermined number of columns having corresponding column indexes; 

bit reversing the row indexes for the first predetermined number of rows and 
permuting the corresponding address locations of the data elements; 
10 bit reversing the column indexesf for the second predetermined number of 

columns and permuting the corresponding address locations of the data elements; 
and 

shifting bit storage locations*^ of one or more of the first predetermined 
number of rows a respective predpermined number of columns. 

15 

2. The method according to claim 1, further comprising the steps of: 
determining an number of bits within a frame to be transmitted and setting 

the predetermined number of bit storage locations equal to A^; and 

setting the first predetermined number of rows and second predetermined 
20 number of columns to 2^" and 2", respectively, where the values m and n are set such 
that 2" is greater than/or equal to N. 

3. The method according to claim 2, wherein the values of m and n are set such 
that n is greater thaiyor equal to m and that the absolute value of the difference of 

25 values m and n is less than or equal to one. 
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4. The method according to claim 1, further comprising the step of reading the 
data elements out of the matrix column by column starting with a first column after 
the columns have been reversed and the rows have been reversed and shifted. 
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5. The method according to claim 1, wherein th^ steps of reversing bit storage 
locations for the first predetermined number of rows, reversing bit storage locations 
for the second predetermined number of colurnns, and shifting bit storage locations 
of each of the second predetermined numbep^f rows a respective predetermined 
number of columns are performed for eacrh data element when each individual data 
element is written to the matrix. 

6. The method according tOM:laim 2, wherein data elements in each particular 
row of the matrix are each shffted in a predetermined direction within the matrix a 
specified number of colum^ as determined by the relationship 2'" - (row# - 1), 
where row# is a number of the particular row in the matrix and 2'" is the total 
number of rows in ttie matrix. 
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elements in the input memory s 
predetermined number of bit st- 
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An interleaver comprisiAg: 
a input device configure 1 for receiving and temporarily storing data elements 
in an input memory, the input c evice also configured to write addresses of the 

equentially by rows into a matrix of at least a 
Drage locations having a first predetermined number 
of rows and a second predetermined number of columns; 

a controller configured o bit reverse row indexes for the first predetermined 
number of rows and permute the corresponding data elements, bit reverse column 
indexes for the second predeter nined number of columns and permute the 
corresponding data elements, and shift bit storage locations of one or more of the 
first predetermined number of lows a respective predetermined number of columns; 
and 

an output device configured to sequentially read the interleaved input 

Limns of the matrix and read and transmit data 
elements stored at correspondirg memory addresses in the sequential read order of 
the interleaved input memory aidresses. 
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8. The interleaver according to claim 7, wherein the controller is further 
configured to: 

determine an A'^ number of bits within a frame to be transmitted; 
set the predetermined number of bit storage locations equal to A^; and 



ed number of rows and second predetermined 



number of columns to 2'" and 
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espectively, where the values m and n are set such 



that 2" is greater than or equal to the at least number of bit storage locations. 

9. The interleaver accord ng to claim 8, wherein the values of m and n are set 
such that n is greater than or equal to m and that the absolute value of the difference 
of values m and n is less than or equal to one. 
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10. The interleaver according to claim 7, where in4ie output device sequentially 
reads the data elements out of the matrix column bVcolumn starting with a first 
column. / 

11. The interleaver according to claim 7,>wherein the controller is configured to 
reverse the bit storage locations for the first predetermined number of rows, reverse 
the bit storage locations for the second prcdetermined number of columns, and shift 
the bit storage locations of each of the /econd predetermined number of rows a 
respective predetermined number of /olumns for each data element when each 
individual data element is written Xp the matrix. 

12. The interleaver accordirig to claim 7, wherein the controller is configured to 
shift data elements in each pa/ticular row of the matrix a predetermined direction 
within the matrix a specifier number of columns as determined by the relationship 
2'" - (row#-l), where row# is a number of the particular row in the matrix and 2'" is 
the total number of row/ in the matrix. 
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13. A data transmission system employing turbo encodins^omprising: 

a turbo encoder for turbo encoding received data frames and transmitting the 
encoded data frames within the data transmission system, the turbo encoder 
including: / 
5 a plurality of coders for coding the receiyed data frame; and 

an interleaver located between an input to the turbo encoder and one of the 
plurality of coder, the interleaver configured to interleave address locations of bits 
within a matrix having a first predeternnned number of rows and a second 
predetermined number of columns by bit reversing row indexes for the first 
10 predetermined number of rows am permuting the corresponding data elements, bit 
reversing column indexes for the second predetermined number of columns and 
permuting the corresponding data elements, and shifting bit storage locations of one 
or more of the first prede^rmined number of rows a respective predetermined 
number of columns; ^vid 
15 a decoder configured to receive and decode the turbo encoded data frames 

transmitted by the turbo encoder, the decoder including a de-inter leaver that 
receives the interleaved reassembles the address locations of bits within the matrix 
by reversing^he interleaved output of the interleaver using reverse steps of the 
interleavefr! 
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14. An interleaver comprisiig: 

an input data memory c ^nfigured to store an number of bits at 
corresponding input data memcry addresses; 

an interleaver matrix configured to read and store the input data memory 
addresses in at least a two-dime nsional matrix having a first predetermined number 
of rows and a second predetern ined number of columns, each of the rows and 

ix value; 

a controller configured th set the first predetermined number of rows and the 
second predetermined number of rows based on the N number of bits using a 

10 prescribed algorithm; the controller also configured to interleave the data memory 
address in the interleaver matrix iy bit reversing the row index values for the first 
predetermined number of rows ana permuting the corresponding address locations 
of the data elements, bit reversing Ithe colunm index values for the second 
predetermined number of columns and permuting the corresponding address 

15 locations of the data elements, and shifting bit storage locations of one or more of 
the first predetermined number of r©ws a respective predetermined number of 
columns; the controller further conngured to read out interleaved data bit addresses 
in the interleaver matrix column by qolumn to produce an interleaved output read 
sequence; 

20 an output buffer receiving the Interleaved output read sequence from the 

controller, the output buffer configured to direct the input data memory to read out 
data bit according to the interleaved output read sequence; and 

an output data memory configured to write data bits read out from the input 
data memory according to the interleaved output read sequence and transmit the 

25 read bits to a communication system. 



15. The interleaver according to claim 1^, wherein the interleaver matrix is 
effected within the controller. 
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>16. The interleaver according to claim 14, wherein the/controller is further 
configured to set the first predetermined number of rows/and second predetermined 
number of columns to 2'" and 2", respectively, where me values m and n are set such 
that 2" is greater than or equal to the at least N niAnber of bit storage locations. 
5 / 

17. The interleaver according to claim 16, wnerein the values of m and n are set 
such that n is greater than or equal to m and that the absolute value of the difference 
of values m and n is less than or equal to oru5. 

10 18. The interleaver according to claim 17, wherein the controller is configured 
to reverse the bit storage locations foythe first predetermined number of rows, 
reverse the bit storage locations for tne second predetermined number of columns, 
and shift the bit storage locations of each of the second predetermined number of 
rows a respective predetermined number of columns for each data element when 

15 each individual data element is written to the matrix. 

19. The interleaver according to claim 14, wherein the controller is configured 
to shift data elements in ea^ particular row of the matrix a predetermined direction 
within the matrix a specified number of columns as determined by the relationship 
20 2^" - (row#-l), where ro^# is a number of the particular row in the matrix and 2"" is 
the total number of rows in the matrix. 



